草庐IT

javascript - 有没有办法让 Chai 处理异步 Mocha 测试?

全部标签

ruby-on-rails - unicorn 超时处理

我想知道从我的应用程序跟踪unicorn超时的最佳方法是什么。该应用程序的某些部分运行缓慢,目前它们已安静地超时。我可以增加超时时间,但这将问题推到了地毯下。理想情况下,我希望收到减速板通知或类似的效果。我不是在寻找性能指南,我只是在寻找一种高效可靠地了解超时的方法。其他人如何使用unicorn处理Rails应用程序的超时?扫描nginx错误日志?在unicorn配置中插入处理程序?nginx配置中的处理程序?[Ubuntu12.04+nginx+unicorn+rails3.2+ruby1.9.3] 最佳答案 我倾向于在NewRe

ruby - 来自 rails 3 中 therubyracer/v8 的 javascript 错误的堆栈跟踪

我正在使用therubyracer和v8在Rails3应用程序中运行一些javascript如果出现任何问题,错误消息将通过通常的Rails3异常通知流程通过电子邮件发送给我。但是,我返回的错误消息非常模糊,堆栈跟踪不会进入javascript文件本身。这是可以理解的,但是很难调试。这是一个例子:V8::JSError:Cannotreadproperty'0'ofundefinedbacktrace:lib/libraryname.rb:32:in`function_that_calls_v8'lib/libraryname.rb:18:in`fetch_and_update'app

ruby - 如何在 Rails 之外使用 less.rb 处理 Bootstrap

我正在尝试使用less.rb创建一个独立的应用程序(独立于RailsAssets管道)以基于TwitterBootstrap输出CSS文件。下面的结果是一个空文档parser=Less::Parser.new:paths=>[Rails.root+'/public/bootstraps/twitter-bootstrap-857b8fb/less']tree=parser.parse("@import'bootstrap.less'")tree.to_css这会导致返回一个空字符串。我尝试了将@import更改为完整路径等的变体,但没有成功。我想我一定遗漏了一些简单的东西。

ruby-on-rails - Rake Assets 在开发或测试组中没有 Gems 预编译

好的,所以我在构建我的Docker镜像时遇到了一个错误(将其视为类似于部署步骤,如果您不熟悉Docker,则可以将其视为Heroku部署)。当预编译步骤发生时,正在寻找:test和:development组中的Gem,因为我已经捆绑了--without开发测试-因为我不想让QT只是为了capybara-webkit不会在bundle上出错-预编译步骤会引发错误。错误总是以下的变体:Couldnotfindinanyofthesources(Bundler::GemNotFound)我的gem文件:source'https://rubygems.org'#BundleedgeRailsi

ruby - 在公式的测试 block 中访问下载的文件

我正在为包含自己的测试套件的C库创建Homebrew公式。作为公式的testblock的一部分,我想运行下载文件中包含的测试。测试作为make目标运行(maketest)。但是,Homebrewtestblock在它们自己的临时目录中运行,下载的文件不在路径中。也就是说,以下内容不起作用,因为它找不到文件:testdosystem"make","test"end如何访问文件最初下载和解压的位置?我无法在文档中找到有关该内容的任何信息。或者在这种情况下是否有更好的Homebrew测试解决方案? 最佳答案 testdoblock旨在测试

ruby-on-rails - 如何使用 ruby​​ 加速大型 CSV 的处理

对于一个项目,我需要解析一些非常大的CSV文件。一些条目的内容存储在MySQL数据库中。我正在尝试使用多线程来加快速度,但到目前为止,这只会减慢速度。我解析了一个CSV文件(最大10GB),其中一些记录(20M+记录CSV中的大约5M)需要插入到MySQL数据库中。为了确定需要插入的记录,我们使用Redis服务器和包含正确ID/引用的集合。由于我们在任何给定时间处理大约30个这样的文件,并且存在一些依赖关系,我们将每个文件存储在一个Resque队列中,并让多个服务器处理这些(优先级)队列。简而言之:classWorkerdefself.perform(file)CsvParser.ea

ruby - 在 Ruby 中,当没有正确的英语 "<verb>able"时,mixins 的命名约定是什么?

示例:我有一个Person类和一个Role类。我想将Role和Person中的角色功能提取到混合中。我得到了两个mixins:Actable包含在Role中,Adaptable用于Person。我有时想不出合适的英文单词。在上面的例子中,适应性似乎更适合角色而不是人,因为角色可以适应,因此是适应性强的。一个更好的名字是versatile但这打破了mixin名字以...able结尾的惯例。(虽然它仍然是一个形容词。)另一个例子是当我想添加一个允许检查的模块时,如果一个人被允许查看其他人。你如何找到以...结尾的名字?Viewable似乎不合适,可以查看的人应该是可见的。我现在坚持使用sh

ruby-on-rails - 如何测试从控制台登录Rails?

我花了很多时间弄清楚如何使用Rails的响应对象登录和注销。标准的博客还可以,但我终于诊断出来了,我想在这里记录一下。app.get'/'assert_response:successapp.get'/auth_only_url'assert_response302user=User.find(:user_to_login)app.post'/signin_url',:user_email=>user.email,:user_password=>''assert_response302app.follow_redirect!assert_response:successapp.get'

ruby - MiniTest - 仅重新运行失败的测试

是否可以让minitest通过rake任务只运行失败的测试?在互联网上找不到任何关于此的信息...使用rspec或cucumber它可以工作。这里有任何可能性吗? 最佳答案 我能找到的最接近的东西是这个插件:https://github.com/ivantsepp/minitest-rerun-options它输出失败测试的命令行选项,如下所示:Rerunfailedtestsoptions:--nameTestExample#test_another_that_will_fail--nameTestExample#test_tha

ruby-on-rails - 使用 rspec 测试 rails 而不需要运行所有初始化程序?

假设您正在开发一个Rails应用程序,它有很多初始化程序,这些初始化程序会在启动时调用各种外部系统。当使用rspec-rails运行rspec时,它会运行所有初始化器,即使您的测试很简单,不需要rails基础设施。我知道您可以使用Spork只产生一次这种成本,但有没有办法完全不产生它?仅仅为了一个简单的PORO规范而加载所有rails似乎很愚蠢。 最佳答案 不要使用spork。如果您想使用预加载器,请查看zeus或spring。您不需要加载整个Rails环境来测试不依赖于Rails的东西。这可以很简单,例如明确要求每个规范所需的依赖